package com.superhelper.common.utils;

import java.math.BigDecimal;

/**
 * 百度地图坐标和火星坐标转换
 */
public class CoodinateCovertor {

    private static double x_pi = 3.14159265358979324 * 3000.0 / 180.0;

    /**
     * 对double类型数据保留小数点后多少位
     * 高德地图转码返回的就是 小数点后6位，为了统一封装一下
     * 
     * @param digit 位数
     * @param in 输入
     * @return 保留小数位后的数
     */
    static double dataDigit(int digit, double in) {
        return new BigDecimal(in).setScale(6, BigDecimal.ROUND_HALF_UP).doubleValue();

    }

    /**
     * 将火星坐标转变成百度坐标
     * 
     * @param c 火星坐标（高德、腾讯地图坐标等）
     * @return 百度坐标
     */

    public static Coordinate toBd(Coordinate c) {
        double x = c.getLongitude(), y = c.getLantitude();
        double z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi);
        double theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi);
        return new Coordinate(dataDigit(6, z * Math.cos(theta) + 0.0065), dataDigit(6, z * Math.sin(theta) + 0.006));

    }

    /**
     * 将百度坐标转变成火星坐标
     * 
     * @param c 百度坐标（百度地图坐标）
     * @return 火星坐标(高德、腾讯地图等)
     */
    public static Coordinate fromBd(Coordinate c) {
        double x = c.getLongitude() - 0.0065, y = c.getLantitude() - 0.006;
        double z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi);
        double theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi);
        return new Coordinate(dataDigit(6, z * Math.cos(theta)), dataDigit(6, z * Math.sin(theta)));

    }

    // 测试代码
    public static void main(String[] args) {
        Coordinate c = new Coordinate(113.311182, 23.11596);
        System.out.println(fromBd(c));
    }

    public static class Coordinate {
        private double longitude;// 经度
        private double lantitude;// 维度

        public Coordinate() {
        }

        public Coordinate(double longitude, double lantitude) {
            this.longitude = longitude;
            this.lantitude = lantitude;
        }

        public double getLongitude() {
            return longitude;
        }

        public void setLongitude(double longitude) {
            this.longitude = longitude;
        }

        public double getLantitude() {
            return lantitude;
        }

        public void setLantitude(double lantitude) {
            this.lantitude = lantitude;
        }

        @Override
        public String toString() {
            return "Coordinate{" + "longitude=" + longitude + ", lantitude=" + lantitude + '}';
        }
    }
}
